package com.da.javatest.leetCode;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

/**
 * @author chenlida
 * @date 2019/1/15 14:44
 * @description
 */
public class Code398 {
    private Map<Integer, List<Integer>> map;

    public Code398(int[] nums) {
        map = new HashMap<>();
        for (int i = 0; i < nums.length; i++) {
            int key = nums[i];
            if (map.containsKey(key)) {
                map.get(key).add(i);
            } else {
                List<Integer> l = new ArrayList<>();
                l.add(i);
                map.put(key, l);
            }
        }
    }

    public int pick(int target) {
        List<Integer> list = map.get(target);
        return list.get((int)(Math.random() * list.size()));
    }
}